<div class="modal fade" role="dialog" aria-modal="true" aria-labelledby="resetPasswordTitle">
  <div class="modal-dialog" role="document">
    <form class="modal-content" #form (ngSubmit)="submit()" [appApiAction]="formPromise">
      <div class="modal-header">
        <h1 class="modal-title" id="resetPasswordTitle">
          {{ "recoverAccount" | i18n }}
          <small class="text-muted" *ngIf="name">{{ name }}</small>
        </h1>
        <button
          type="button"
          class="close"
          data-dismiss="modal"
          appA11yTitle="{{ 'close' | i18n }}"
        >
          <span aria-hidden="true">&times;</span>
        </button>
      </div>
      <div class="modal-body">
        <app-callout type="warning"
          >{{ "resetPasswordLoggedOutWarning" | i18n: loggedOutWarningName }}
        </app-callout>
        <auth-password-callout
          [policy]="enforcedPolicyOptions"
          message="resetPasswordMasterPasswordPolicyInEffect"
          *ngIf="enforcedPolicyOptions"
        >
        </auth-password-callout>
        <div class="row">
          <div class="col form-group">
            <div class="d-flex">
              <label for="newPassword">{{ "newPassword" | i18n }}</label>
              <div class="ml-auto d-flex">
                <a
                  href="#"
                  class="d-block mr-2 bwi-icon-above-input"
                  appStopClick
                  appA11yTitle="{{ 'generatePassword' | i18n }}"
                  (click)="generatePassword()"
                >
                  <i class="bwi bwi-lg bwi-fw bwi-refresh" aria-hidden="true"></i>
                </a>
              </div>
            </div>
            <div class="input-group mb-1">
              <input
                id="newPassword"
                class="form-control text-monospace"
                appAutofocus
                type="{{ showPassword ? 'text' : 'password' }}"
                name="NewPassword"
                [(ngModel)]="newPassword"
                required
                appInputVerbatim
                autocomplete="new-password"
              />
              <div class="input-group-append">
                <button
                  type="button"
                  class="btn btn-outline-secondary"
                  appA11yTitle="{{ 'toggleVisibility' | i18n }}"
                  (click)="togglePassword()"
                >
                  <i
                    class="bwi bwi-lg"
                    aria-hidden="true"
                    [ngClass]="{ 'bwi-eye': !showPassword, 'bwi-eye-slash': showPassword }"
                  ></i>
                </button>
                <button
                  type="button"
                  class="btn btn-outline-secondary"
                  appA11yTitle="{{ 'copyPassword' | i18n }}"
                  (click)="copy(newPassword)"
                >
                  <i class="bwi bwi-lg bwi-clone" aria-hidden="true"></i>
                </button>
              </div>
            </div>
            <app-password-strength
              [password]="newPassword"
              [email]="email"
              [showText]="true"
              (passwordStrengthResult)="getStrengthResult($event)"
            >
            </app-password-strength>
          </div>
        </div>
      </div>
      <div class="modal-footer">
        <button type="submit" class="btn btn-primary btn-submit" [disabled]="form.loading">
          <i class="bwi bwi-spinner bwi-spin" title="{{ 'loading' | i18n }}" aria-hidden="true"></i>
          <span>{{ "save" | i18n }}</span>
        </button>
        <button type="button" class="btn btn-outline-secondary" data-dismiss="modal">
          {{ "cancel" | i18n }}
        </button>
      </div>
    </form>
  </div>
</div>
